技術問答
技術文章
iT 徵才
Tag
聊天室
2025 鐵人賽
登入/註冊
問答
文章
Tag
邦友
鐵人賽
搜尋
2023 iThome 鐵人賽
0
Modern Web
前端知識
系列 第
29
篇
10 React Antipatterns to Avoid - Code This, Not That!
15th鐵人賽
jasonchenchen
2023-10-29 16:55:49
819 瀏覽
分享至
React Anti-patterns and Solutions
Anti-pattern 1: Big Components
Problem
: Starting off with one big, deeply nested component.
Solution
: Refactor into smaller, reusable components.
Anti-pattern 2: Nesting Components
Problem
: Defining child components inside parent components.
Solution
: Define child components outside the parent component.
Anti-pattern 3: Failure to Memoize
Problem
: Running expensive calculations every time the state changes.
Solution
: Use the `useMemo` hook.
Anti-pattern 4: Useless Divs
Problem
: Wrapping multiple elements in unnecessary `div` tags.
Solution
: Use React Fragments.
Anti-pattern 5: Messy Files
Problem
: Exporting multiple components from a single file.
Solution
: One component per file.
Anti-pattern 6: Big Bundles
Problem
: Slow initial page load due to large JavaScript bundles.
Solution
: Use code splitting and lazy loading.
Anti-pattern 7: Prop Drilling
Problem
: Passing state through multiple layers of components.
Solution
: Use context API for global state management.
Anti-pattern 8: Prop Plowing
Problem
: Components with a lot of different props.
Solution
: Use the spread syntax.
Anti-pattern 9: Messy Event Handlers
Problem
: Using arrow functions for event handlers with multiple arguments.
Solution
: Use curried functions.
Anti-pattern 10: Single Object State
Problem
: Using a single object for all state in a component.
Solution
: Use multiple `useState` hooks, and extract to custom hooks
留言
追蹤
檢舉
上一篇
Better optimistic update
下一篇
ts-reset
系列文
前端知識
共
30
篇
目錄
RSS系列文
訂閱系列文
2
人訂閱
26
Learn React Hooks: useRef - Simply Explained!
27
Next.js 14.0 ( server action )
28
Better optimistic update
29
10 React Antipatterns to Avoid - Code This, Not That!
30
ts-reset
完整目錄
熱門推薦
{{ item.subject }}
{{ item.channelVendor }}
|
{{ item.webinarstarted }}
|
{{ formatDate(item.duration) }}
直播中
立即報名
尚未有邦友留言
立即登入留言
iThome鐵人賽
參賽組數
902
組
團體組數
37
組
累計文章數
19843
篇
完賽人數
529
人
看影片追技術
看更多
{{ item.subject }}
{{ item.channelVendor }}
|
{{ formatDate(item.duration) }}
直播中
熱門tag
看更多
15th鐵人賽
16th鐵人賽
13th鐵人賽
14th鐵人賽
17th鐵人賽
12th鐵人賽
11th鐵人賽
鐵人賽
2019鐵人賽
javascript
2018鐵人賽
python
2017鐵人賽
windows
php
c#
linux
windows server
css
react
熱門問題
如何找到電腦網路行為的觸發原因?
檔案伺服器移轉
Exchange EMS掛掉導致Q信(2016)
從資訊安全角度分析:若電子支付平台疑遭暗網販售資料,可能的技術成因與防護機制?
win11 bitlocker 除了格式化重灌外, 有解嗎?
Exchange 2016 手機無法登入
Gmail 寄件備分 一次變成 Gmail聯絡人寄出
請問要如何將github下載下來的檔案轉成dll檔
熱門回答
檔案伺服器移轉
如何找到電腦網路行為的觸發原因?
從資訊安全角度分析:若電子支付平台疑遭暗網販售資料,可能的技術成因與防護機制?
熱門文章
Microsoft Certified: Azure Administrator Associate AZ-104認證考試介紹
📨 用 n8n 自動整理信用卡帳單:從 Gmail 到 LINE 的實戰筆記
Portainer:從入門到入土心得錄01
【專案實戰】我在專案裡,用需求追溯矩陣讓 PM、工程師和法遵站在同一頁
[Day 27]隨機密碼產生器
IT邦幫忙
×
標記使用者
輸入對方的帳號或暱稱
Loading
找不到結果。
標記
{{ result.label }}
{{ result.account }}